草庐IT

postgresql - 在 docker 环境中重启 postgres

全部标签

docker - 使用 Go docker SDK 的二进制 TLS 配置失败

我有一个golang二进制文件,它使用TLS与远程docker守护进程通信。二进制文件在本地计算机上成功运行。但是在dockerubuntu容器中运行此二进制文件时,tls配置失败。它因以下错误而panic/usr/local/go/src/crypto/x509/cert_pool.go:96+0x6bcrypto/x509.(*CertPool).AppendCertsFromPEM(0x0,0xc4202bd4c8,0x0,0x200,0xac8)/usr/local/go/src/crypto/x509/cert_pool.go:128+0x161github.com/dock

postgresql - 如何创建一个在列中包含 slice 的表

我有一个看起来像这样的模型:typeInventorystruct{gorm.ModelLocationIDstringItems[]Item//thisisasliceofstructsCategories[]Category//thisisasliceofstructs}当我使用gorm为它创建一个表时,我没有项目或类别的列。我错过了什么? 最佳答案 因为数组在SQL中不支持列类型——至少大多数版本的SQL是这样——gorm不会为slice类型的字段创建列。但是,您可以在使用关联后创建您现在的关系结构。在这种情况下,has-ma

unix - 如何将命令行选项传递给我的 dockerized GoLang 程序?

我有一个简单的dockerizedgolang程序,我希望能够在运行容器时向它发送命令行选项。我的Dockerfile如下所示:FROMgolang:onbuildRUNgoget[MYPROGRAM] 最佳答案 只要您的应用按照Go约定编译为单个二进制文件,您就应该能够使用下面这个简单的两行代码,在ENTRYPOINT指令中将任何后续标志作为类似数组的参数传递。FROMgolang:onbuildENTRYPOINT["/go/bin/app","-name=foo","-title=bar"]

postgresql - PostgreSQL 查询中具有模式匹配语法的参数

这个问题在这里已经有了答案:GopostgresqlLIKEquery(6个答案)关闭1年前。我正在编写一个查询postgres数据库的golang程序。我想使用$1来提供值并且应该有模式匹配Db.Query("SELECT*FROMtablewherenamelike%$1%",user)它说:syntaxerroratornear"%"

sql - Golang sql 包查询比 PostgreSQL SQL 查询慢

我正在使用GolangSQL包来调用我的数据库。我正在使用准备好的语句,并且在列上有索引stmtHas:=db.Prepare(`SELECTvalueFROM`+tableName+`WHEREkey=$1;`)now:=time.Now()err:=db.stmtGet.QueryRow(key).Scan(&value)elapsed:=time.Since(now)fmt.Println(elapsed)这会打印-40.874782ms然而,与此相比,原始SQL查询花费的时间要少得多。EXPLAIN(ANALYZE,BUFFERS)SELECTvalueFROMtableNam

go - golang中根据环境配置数据库细节

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion要求:在golang中根据环境(如QA、PROD)配置数据库连接。例如:{"QA":{"host":"124.44.2.2","port":"1234"},"PROD":{"host":"125.65.23.64","port":"1234"}}我可以在JSON/YAML等中配置它,但问题是当我们构建go时,构建文件不包含非go文件。因此,当将构建部署到不同的实例时,它会丢失配置文件。另一

go - 如何检测当前 Go 进程是否在 headless (headless)(非 GUI)环境中运行?

我有一个要安装托盘图标的Go程序。如果进程是headless(headless)的,即无法创建图形用户界面,Go程序仍然有意义并应该运行,但显然它不会安装托盘图标。Go中检测当前Go进程是否headless的方法是什么?目前,我使用以下代码:funcisHeadless()bool{_,display:=os.LookupEnv("DISPLAY")return!(runtime.GOOS=="windows"||display)}此代码在“普通”Windows、Linux或MacOSX上运行良好,我敢打赌它在FreeBSD、NetBSD、Dragonfly和许多其他系统上也能正常运行

go - 如果停止,如何自动重启 go web 服务器

我尝试应用一种机制,允许goweb服务器在停止时自动重新启动。我的做法是将server.ListenAndServe()置于无限循环中。由于.ListenAndServe()是阻塞的,我觉得这样做是可以的。以下是完整代码:funcmain(){//...isStarted:=falsefortrue{ifisStarted{fmt.Println("=====================================RESTARTINGWEBSERVER")}log.Println(server.ListenAndServe())isStarted=truetime.Sleep(

go - 如何查询和处理使用 go.uuid 创建并插入到 PostgreSQL 11 中的 UUID?

我在PostgreSQL表中插入了一个使用go.uuid创建的UUID:import("github.com/satori/go.uuid")funcmain(){usid:=uuid.Must(uuid.NewV4())fmt.Println("usid:=uuid.Must(uuid.NewV4")fmt.Println(usid.String())res,err:=stmt.Exec(cn,csn,ccn,id)iferr!=nil||res==nil{log.Fatal(err)}}sStmt:="insertintobasicuserinfo(cn,csn,ccn,appUs

git - 使用 Docker 在生产中部署 Go 服务

我正在使用Docker开发Go服务,并认为在编译时要在生产中部署代码,我只需要dockercompose和在我的注册表上发布的Docker镜像。因为我来自PHP世界,所以我习惯于克隆我的整个项目来部署它。有什么方法可以仅使用docker-compose文件部署我的项目?我在thispost上看到了我只能gitclone一个文件,但感觉这不是一个好方法,用Docker部署Go微服务的最佳实践是什么? 最佳答案 您的问题中有两个不同的问题,我不确定您要寻找哪个问题的答案。Q1:为我的Go项目创建Dockerfile的好方法是什么A1:看